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jg) Secondary processor Initialization scheme. 

@ In a. microprocessor based computer^systern having a 
primary unit (10) such as a system board ami a secondary unit 
(20) such as an adapter card.^the secondary processor (21 ),p 
which ls heid in a n^^ on the / 

[Secondary unit can be initialized without requiring a read only 
storage (ROS) module or a read onl y memory (ROM) module to? . 
be a part of the secondary unit Specifically, a window is defined 
from a segment of u reinstalled memory address space from the 
primary unit and a segment of Installed memory address space 
from the secondary unit. The primary processor (11) on the 
primary unit retrieves the secondary processor's jnftialtzation 
\ program from the primary unit's nort-volatSe .storage (17). This^ 
initialization program (also known ^^X^cp^s^^\\ ! ( 0 ^ 
program) is then^ptaced in the window. Trw primary processor 
then oQsables trTe fes^ line of the secondary processor. Upon 
having its reset ftne'dlsabted, the secondary procossor-begins 
execu^ng^the^mitialization program. After the inmaflzation 
jxogram.has^comj^ted, the primaly^unit p an send other/ 
preparatory programs J such as diagmisfe progranTs to me F 
secondary unit through the window^ When ail of the preparatory 



rj roQrarns . r «ve i be e n.cornpleted. the contents .c^theMfeP^^ 0 
dveTwrme^ unit's memory and *me -secondary / 

unit's mlhiqry can be fully utilized for other interprocessor/ 
communi^^ embodiment is also disclosed 

where a shared memory address space is used? 
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Description 

SECONDARY PROCESSOR 

This invention relates to the data processing field. 
More particularly, this invention is a computer 
system having a primary unit and a secondary unit 5 
where the primary unit controls the initialization of 
the secondary unit 

The typical microprocessor based computer sys- 
tem has a system board that contains a primary 
processor. Typically, this system board contains 10 
slots into which one or more adapter cards can be 
plugged These adapter cards can be for controlling 
a printer, a display, or communications between 
other computers, just to name a few functions. Often 
these adapter cards contain a secondary micropro- 15 
cessor used to control the specific function of that 
particular adapter card. 

In addition to a secondary processor, adapter 
cards often also contain a read only storage (ROS) 
or read only memory (ROM) module. This ROS (or 20 
ROM) module is used to permanently store an 
initialization program (otherwise known as an initial 
boot record) even when the power to the adapter 
card is off. When power Is first provided to the 
adapter card, the secondary processor, as its first 25 
activity, executes the initialization program con- 
tained in the ROS module. This program initializes 
the secondary processor, the random access mem- 
ory (RAM), and other hardware contained on the 
adapter card. 30 

The requirement of havln^a ROS (or ROM)^/ 
module on an adapter card to permanently store the 
[initializati6ri»p^^ 

f telgc^K^jS^^ s |^ increases the time^ 
r^uir^ adtapter card, and makes 35 

field changes or updates of the adapter card 

Mhitializatidril^ T~~ ' 

--It is a principal object of the invention to provide 
for the initialization of a secondary processor on an 
adapter card or other secondary unit where an 40 
on-board ROS or ROM module is not required to 
store the initialization program. 

It is another object of the invention to provide a 
simplified method of initializing a secondary proces- 
sor on an adapter card or other secondary unit 45 
where the initialization program can be easily 
modified. 

It is still another object of the invention to reduce 
the cost and time of developing adapter cards or 
other secondary units for computer systems. 50 

These and other objects are accomplished by the 
secondary processor initialization scheme disclosed 
herein. 

In a microprocessor based computer system 
having a primary unit (such as a system board) and a 55 
secondary unit (such as an adapter card), the 
secondary processor (which is held in a non-running 
reset state) contained on the secondary unit can be 
initialized without requiring a read only storage 
(ROS) module or a read only memory (ROM) module 60 
to be a part of the secondary unit Specifically, a 
window is defined from a segment of uninstailed 
memory address space from the primary unit and a 
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segment of installed memory address space from 
the secondary unit The segment of memory from 
the secondary unit includes the secondary proces- 
sor instruction addresses which are initially ex- 
ecuted. The primary processor on the primary unit 
retrieves the secondary processor's initialization 
program from the primary unit storage. This Initializa- 
tion program is then placed in the window. The 
secondary processor does not need to be running 
for primary processor window accesses. The pri- 
mary processor then disables the reset line of the 
secondary processor. Upon having its reset line 
disabled, the secondary processor begins executing 
the initialization program. In this manner, the 
secondary unit is initialized without the requirement 
of an on-board ROS or ROM module. After the 
initialization program has completed, the primary 
unit can send other preparatory programs, such as 
diagnostic pro-grams, to the secondary unit through 
the window. When all of the preparatory programs 
have been completed, the contents of the window 
are overwritten so the primary unit's memory and the 
secondary unit's memory can be fully utilized for 
other interprocessor communications. 

Fig. 1 shows a block diagram of the primary 
unit and the secondary unit of the invention. 

Fig. 2A shows how the window is created 
from the primary memory address space and 
the secondary memory address space in the 
preferred embodiment of the invention. 

Fig. 2B shows how the window is created 
from the primary memory address space and 
the secondary memory address space in an 
alternate embodiment of the invention. 

Fig. 2C shows an alternate embodiment of 
the invention using a shared memory scheme. 

Fig. 3 shows the I/O registers of the 
secondary unit in more detail. 

Figs. 4A-4B show a flow chart of the 
programmed primary processor of the inven- 
tion. 

Rgs. 5A-5B show a flow chart of the 
programmed secondary processor of the Inven- 
jtion. 

/Fig^-lr shows an overall blo ck dia g ram of the 
prirnarv u^nit and secondalyljr^of tr^^ 
the preferred embodimentrpnmary unit 10 jis the 
r system-boaro* of an IBM PERSONAL SYSTEM/2 
computer, although primary unit 10 could also be the 
primary unit of any computer; Secondary unit;20 m 
the preferred embodiment is ran adapter carcTsuchF 
as the IBM 69X6279 adapter card used on the IBM 
Personal System/2 computer, although secondary 
unit ^jioes not necessarily have to be an adapter 
rc^rSecondary unit 20 c ould conceivably be a 
section_o^^rnalri : l^ 
specjairzetP^ 

processor. In addition, secondary unit 20 could be a 
remote device, such as a terminal, connected to 
primary unit 10 via a communications line. 
Primary unit 10 will now be described in more 
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detail. Primary unit 10 contains a primary central 
processor unit "11. ) In the preferred embodiment, 
primary processor 11 is a microprocessor such as 
an INTEL 80286 or 80386 microprocessor, although 
other processors could also be used. Processor 11 7 5 
is connected to primary random access memory 12,7 
non-volatile storage 17, and read onlystorage (ROS) 
18.^ Norvvoiatiie' storage 17 is typically a disk, 
diskette, tape, optical disk or other secondary' 
storage device that retains its stored information' 10 
after power is turned off. ROS 18 is used in a? 
conventional manner to permanently store the J 
initiatotion program for the pnmary unit. -Primary 
procesiorlt* primary memory address space 12/ 
storage 17 and ROS 18 are ail connected to system f 15 
bus 19 which connects to secondary unit 20. 
Secondary unit 20 contains secondary processor 21, 

r \JO registers 30 and secondary memory address 
space 22. Secondary processor 21-, in the preferred 
embodiment, is a INTEL 8088 microprocessor 20 
although other processors could also be used. 
Registers 30 are shown in more detail in Fig. 3 and 
wiD be discussed later. 

Fig;2Asfiows primarym^ 
and secondary- me^r^ a^ddress ' Sf»ce 22 of the 25 
preferred^embodiment of the invention in more 
detail. Note that primary memory address space 12 
is shown to be larger than secondary memory 
address space 22. This would typically be the case 
but is not necessarily required for this Invention. 30 

rPrimary memory address-space 12 contains uhih 5 
stalled primary memory 14 and installed primary 
nrnmc^jilS. |Uninstalled primary memory 14 is 
addressable despitejthe fact |t Is not ihstalleS. A 
segment of uninstalled primary memory 14 is 35 
designated as primary memory vvindow location 13. 7 
Secondary memory address space 22. contains 
installed secondary memory 25. A segment of 
Installed -secondary memory 25"is designated as 7 

l^mm^^^^^^\^^^ 40 

During the initialization and preparatory process, 
as will be discussed in more detail later, memory 
locations 13 and 23 contain the same data and will be 

Ireterred'to ^nectrvely^ window 50.' It is important 
to keep in mindrhowever, that window 50 is defined 45 
by primary memory window location 13, as accessed 
by primary processor If, and secondary-memory^ 

r window Ideation -23, as accessed by secondary 

rprpcessor 21 (once itnms)» during the initialization 
and preparation of secondary unit 20. When primary SO 
processor 11 accesses primary memory window 
location 13, it is accessing data contained in the real 
memory of secondary memory window location 23. 

Fig. 2B shows primary memory address space 12 
and secondary memory address space 22 of a first 55 
alternate embodiment in more detail. Note that 
primary window location 13 is in installed primary 
memory 15 instead of uninstalled primary memory 
14, as was the case in the preferred embodiment. 
When secondary processor 21 writes data to 60 
secondary window location 23, the same data must 
be written to primary window location 13. This Is not 
required in the preferred embodiment. 

'Rgr2Crsruws^th¥7shared:rrrem of a 

second alternate embodiment. In this alternate 65 



embodiment, primary processor 11 and secondary 
-processor 21 both access shared memory address 
space 62 via bus 19. 7 0nry one processor can access 
shared memoryradotress ^ace 62 aj a timerso tt^ 
data integrity is preserved. ^ 

Fig. 3 shows I/O registers 30 of secondary unit 10 
in more detail. Registers~31and 33 are Tused to* 
define the rbegbrmin(J address of primary memory 
window location 13rin the preferred embodiment, 
primary memory window location 13 is 16 kilobytes in 
size, although this could be considerably smaller or 
larger or dynamically variable and still fall within the 
scope "of ttie^ invention. Also, in the preferred 
embodiment, primary memory address space 12 is 
one megabyte in size and secondary memory 
address space 22 is 256 kilobytes in size, although 
these also could be much smaller or larger and still 
fall within the scope of the invention. 

Registers 31 and 33 contain 10 address lines, 
AM14-AM23. These 10 address Ones are sufficient to 
address any 16 kilobyte segment of the one 
megabyte of total memory addressability in primary 
memory address space 12. Clearly, more or less 
address lines could be used for addressing if either 
primary window location 13 or primary memory 
address space 12 were of different sizes than that of 
the preferred embodiment. 

Register 32 is used to address the beginning of 
secondary window location 23 in secondary memory 
address space 22. Note that register 32 contains 
four address lines PS1-PS4. These four address 
lines are sufficient to address any 16 kilobyte 
segment in the 256 kilobytes of secondary memory 
address space 22. Again, the number of address 
lines in register 32 can be changed if the size of 
either primary window location 23 or secondary 
memory address space 22 is different than that of 
the preferred embodiment. 

Register 34 is used to tell the primary unit if the 
secondary unit is installed, and contains the identifi- 
cation of the secondary unit. 

Register 36 contains processor reset line 37 for 
resetting secondary processor 21. In the preferred 
embodiment, when processor reset line 37 Is 
disabled, secondary processor 21 automatically 
jumps to secondary memory address space 22 and 
begins executing the first instruction contained 
there. 

Figs. 4A-4B show the flow chart of programmed 
primary processor 11. Block 101 asks if secondary 
unit 29 is installed. This is determined by looking at 
the contents of register 34. If register 34 contains the 
ID of secondary unit 20, then primary unit 10 knows 
that secondary unit 20 is installed and block 101 is 
answered affirmatively, ff secondary unit 20 is not 
installed, an error message is displayed In block 102 
and the program exits in block 103. If secondary unit 
20 is installed, flow of control moves to block 104 
where the beginning address of primary memory 
window location 13 is sent to registers 31 and 33 of 
secondary unit 20. In this manner, secondary unit 20 
is informed of the primary memory window location. 
Block 105 sets the secondary memory window 
location by writing the address of the beginning of 
the secondary memory, window location 23 to 
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register 32. Secondary memory window location 23 
must include the secondary processor power-on 
reset execution location. 

Block 106 tests secondary window location 23 to 
assure that this memory is operating property. Block 
107 then reads the secondary processor initialization 
program from storage 17 of primary unit 10. This 
initialization program could also be located in ROS 
18 or some other non-volatile storage device part of 
primary unit 10. Block 108 then copies the secondary 
processor Initialization program into window 50 
created by primary memory window location 13 and 
secondary memory window location 23. Row of 
control then moves to Fig. 4B. 

Block 109 places a jump instruction to the start of 
the initialization program at the secondary proces- 
sor's power-on reset execution address in second- 
ary memory address space 22 contained in window 
50. Block 110 removes the reset condition from the 
secondary processor. This is done by writing to 
register 36, thereby disabling processor reset line 
37. When processor reset line 37 is disabled, 
secondary processor 21 is started as shown in block 
200. The operation of secondary processor 21 is 
shown in more detail in Figs. 5A and 5B and will be 
discussed later. 

Primary processor 11 watts for secondary proces- 
sor 21 toxomplete the initialization process and put 

/an initialization compjetipn„codejn window 50/as 
sHowrTih blocks 112lfid 113. In the event the time 
out period elapses before the Initialization comple- 
tion code appears in window 50, an error code is 
displayed in block 1 14 and the program exits in block 
115. Otherwise, primary processor 1 1 loops between 
blocks 112 and 113 waiting for the initialization 
completion code from secondary processor 21. 
Once secondary processor 21 places an Initialization 
completion code in the window, block 116 checks to 
see if this completion code indicates that secondary 
processor 21 has been initialized property. If not, an 
error code is displayed in block 114 and the program 
exits in block 115. If so, block 117 reads a 
diagnostics or other preparatory program from 
storage 17 and transfers this program to window 50, 
one block at a time. Note that primary processor 11 
will receive a completion code via window 50 from 
secondary processor 21 after each block has been 
successfully transferred. _ 
crAfter primary processor 11recejyes a completion^? 

r code^fr^om"the prc>gramCthat the program has/ 
successfully jcompleted (blocks 112 and 126), con- 
trol loops back to block 1 17 and then^prBpara^oTy? 
program (rf block 127 determines there is one) Is 
transferred to window 50. In the event the time out 
period elapses before the completion code appears 
in window 50, an error code is displayed in block 124. 
The capability described above allows programmers 
much flexibility in controlling the initialization and 
preparation process of secondary unit 20. When all 
of the diagnostics or other preparatory programs 
have been transferred through window 50 to sec- 
ondary processor 21 and successfully executed, 
primary processor 1 1 overwrites the last block of the 
last preparatory program In window 50 but continues 
to use window 50 to communicate with secondary 



processor 21 by sending requests and data and 
receiving requests, status and data from secondary 
processor 21. 
Note that if the preparatory program is less than or 
5 equal to the size of window 50, it would not be 
necessary to break It into blocks and move to a 
different location in secondary memory. Instead, the 
program can be executed directly from window 50 in 
a manner similar to how the initialization program is 

10 executed. 

Figs. 5A-5B show a flow chart of programmed 
secondary processor 21. Block 201 indicates that 
pf c^ e^ jj|j^e rfine 37 of register 36 has been 
disabfealana^sec^rkJary processor 21 has been 

15 reset. In block 202, processor 21 jumps to the start 
of the initialization program that is the destination of 
the jump instruction placed in secondary memory 
address space 22 by processor 11 in block 109. 
Block 203 tests the operation of secondary proces- 

20 sor 21 and its associated registers. In block 204, 
secondary processor 21 tests the portion of second- 
ary memory address space 22 not part of secondary 
memory window location 23. Block 205 performs any 
other initialization steps that may be required, and 

25 block 206 informs the primary processor of the 
completion of the initialization. This is done by 
placing a completion code in window 50. If second- 
ary processor 21 has completed initialization suc- 
cessfully, a successful completion code is placed in 

30 window 50. However, if secondary processor 21 has 
not completed initialization successfully (due to a 
detected failure of one of the tests in blocks 203 or 
204), an unsuccessful completion code is placed in 
window 50. This completion code is analyzed by 

35 primary processor 1 1 in block 1 16 of Fig. 4B, as has 
been discussed. Flow of control then moves to block 
207 in Fig. 5B. 

Block 207 warts for a block of a diagnostic or other 
preparatory program to be placed in window 50 by 

40 primary unit 10. Block 209 copies this block of a 
diagnostic or other preparatory program to a 
designated area of secondary memory address 
space 22. Block 214 notifies the primary processor 
of the completion of the block transfer operation by 

45 writing a completion code into window 50. Block 21 0 
then looks to see if this is the last block of the 
program to be transferred. If not, block 211 loops 
until another block has been loaded. When another 
block has been loaded, flow of control returns back 

50 to block 209 where the additional block is then 
copied into secondary memory address space 22. 

When block 21 0 indicates that the last block of the 
program has been transferred, block 212 passes 
control to the entry point of the program just loaded 

55 in secondary memory address space 22. 

In block 213, the loaded program runs and sends a 
completion code to primary processor 11 indicating 
successful execution. The loaded program then 
returns control to secondary processor 21 if it is not 

60 the last preparatory program to be executed. If block 
213 returns control, flow of control returns to block 
207 where secondary processor 21 waits for a block 
of an additional diagnostic or other preparatory 
program to appear in the window from primary unit 

65 10. If block 213 does not return control, the loaded 



4 



7 



EP 0335 812 A2 



8 



program was the last preparatory program, and 
secondary window location 23 is overwritten and 
used by secondary processor 21 to communicate 
with primary processor 11, as has already been 
discussed. 5 

if the second alternate embodiment shown in 
Fig. 2C is used, the flow charts shown in Figs. 4A-4B 
and 5A-5B would be modified slightly. Specifically, 
the window concept would be replaced by the 
shared memory concept For example, block 108 10 
would read "copy secondary processor initialization 
program into shared memory address space." The 
jump instruction placed at the POR execution 
addres in block 109 would cause the secondary 
program to jump to the shared memory. Likewise, all 15 
completion codes would be sent to shared memory 
62 by secondary processor 21 and read from shared 
memory 62 by primary processor 11. 

While the invention has been described with 
respect to the preferred embodiment it will be 20 
understood by those skilled in the art that various 
changes in detail may be made therein without 
departing from the spirit scope and teaching of the 
invention. For example, the primary and second 
processor could operate more in a master/slave 25 
relationship, where the primary processor com- 
pletely controls the transfer of blocks of diagnostic 
or preparatory programs to the secondary memory 
without assistance of the secondary processor. This 
could be done by moving the window around the 30 
secondary memory. In addition, the initialization 
program could be larger than the size of window 50. 
In this event, the initialization program would be 
broken into blocks and sent to secondary unit 20 in a 
manner similar to how the diagnostics or other 35 
preparatory programs are sent, as described in 
blocks 117-127 in Fig. 4B. 



Claims 40 

1. A method of initializing jaTsecbliidary unitf 
having a secondary processor, from a primary 7 
f unit taving a^rimary processor, comprising the 
steps of : 45 
defining a window from primary memory ad- 
dress space in said primary unit and from 
secondary memory address space in said 
secondary unit; 

retrieving an inffiafizatioh - program~~fdr saidf 50 
^secohlJaryaunrt^^ primary 

<- ufirf — — " J 

placing-said initialization program in said wfr*- 

dow; .. -•• - ~ ' 

disabling the™reset"One of ~ said ^secondary^ 55 
processoriby said primary processor; and 
initializing said seconga^^ 
initialization=program^ window/ 
J^2. The method of claim 1, further comprising 
the steps of: 60 
retrieving a preparatory program for said sec- 
ondary unit from said storage; 
placing said preparatory program in said win- 
dow; and 

executing said preparatory program by said 65 



secondary processor. 

3. The method of claim 1, further comprising 
the steps of: 

retrieving a first block of a preparatory program 
fro said secondary unit from said storage ; 
placing said first block in said window; 
copying said first block into said secondary 
memory; 

repeating said retrieving, placing, and copying 
steps until said preparatory program is in said 
secondary memory; and 
executing said preparatory program by said 
secondary processor. 

4. A computer system comprising a primary 
unit connected to a secondary unit, said primary 
unit comprising a primary processor, a primary 
memory and a primary storage; said secondary 
unit comprising a secondary processor, and a 
secondary memory; said computer system 
further comprising: 

means for defining a window from said primary 
memory address space and said secondary 
memory address space ; 
means for retrieving an initialization program for 
said secondary unit from said primary storage; 
means for placing said initialization program in 
said window; 

means for disabling the reset tine of said 
secondary processor by said primary proces- 
sor; and 

means for initializing said secondary processor 
from said initialization program contained in 
said window. 

5. The computer system of claim 4, further 
comprising: 

means for retrieving a preparatory program for 
said secondary unit from said primary storage; 
means for placing said preparatory program in 
said window; and 

means for executing said preparatory program 
by said secondary processor. 

6. The computer system of claim 4, further 
comprising: 

means for retrieving a first block of a prepara- 
tory program for said secondary unit from said 
primary storage; 

means for placing said first block in said 
window; 

means for copying said first block into said 
secondary memory; 

means for repeating said retrieving, placing, and 
copying steps until said preparatory program is 
in said secondary memory; 
means for executing said preparatory program 
by said secondary processor. 

7. A method of initializing a secondary unit 
having a secondary processor, from a primary 
unit having a primary processor, said primary 
unit and said secondary unit connected to a 
shared memory address space, comprising the 
steps of: 

retrieving an initialization program for said 
secondary unit from storage in said primary 
unit; 

placing said initialization program in said shared 
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memory address space ; 
disabling the reset line of said secondary 
processor by said primary processor; and 
initializing said secondary processor from said 
initialization program contained in said shared 5 
memory address space. 

8. The method of claim 7, further comprising 
the steps of: 

retrieving a preparatory program for said sec- 
ondary unit from said storage; 10 
placing said preparatory program in said shared 
memory address space; and 
executing said preparatory program by said 
secondary processor. 

9. A computer system comprising a primary 15 
unit connected to a secondary unit, said primary 

unit and said secondary unit connected to a 
shared memory address space, said primary 
unit comprising a secondary processor, and a 
secondary memory; said computer system 20 



further comprising: 

means for retrieving an initialization program for 
said secondary unit from said primary storage; 
means for placing said initialization program in 
said shared memory address space ; 
means for disabling the reset line of said 
secondary processor by said primary proces- 
sor; and 

means for initializing said secondary processor 
from said initialization program contained in 
said shared memory address space. 
10. The computer system of claim 10, further 
comprising: 

means for retrieving a preparatory program for 
said secondary unit from said primary storage; 
means for placing said preparatory program in 
said shared memory address space; and 
means for executing said preparatory program 
by said secondary processor. 
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ABSTRACT : 

CHG DATE=19990617 STATUS=0> In a microprocessor based 
computer system having 

a primary unit (10) such as a system board and a secondary 
unit (20) such as an 

adapter card, the secondary processor (21), which is held 
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in a non-running 

reset state, contained on the secondary unit can be 
initialized without 

requiring a read only storage (ROS) module or a read only 
memory (ROM) module 

to be a part of the secondary unit. Specifically, a window 
is defined from a 

segment of uninstalled memory address space from the 
primary unit and a segment 

of installed memory address space from the secondary unit. 
The primary 

processor (11) on the primary unit retrieves the secondary 
processor ' s 

initialization program from the primary unit's non-volatile 
storage (17) . This 

initialization program (also known as an IPL program or a 
boot program) is then 

placed in the window. The primary processor then disables 
the reset line of 

the secondary processor. Upon having its reset line 
disabled, the secondary 

processor begins executing the initialization program. 
After the 

initialization program has completed, the primary unit can 
send other 

preparatory programs, such as diagnostic programs to the 
secondary unit through 

the window. When all of the preparatory programs have been 
completed, the 

contents of the window are overwritten so the primary 
unit's memory and the 

secondary unit's memory can be fully utilized for other 
interprocessor 

communications. An alternate embodiment is also disclosed 
where a shared 

memory address space is used. 
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